﻿
-- ================================================
-- Remarks: 
-- ================================================
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

IF EXISTS (SELECT * FROM sysobjects WHERE type = 'P' AND name = 'Ivy_UserRole_Update')
	BEGIN
		DROP  Procedure  Ivy_UserRole_Update
	END

GO

CREATE PROCEDURE [Ivy_UserRole_Update] 
-- =============================================
-- Author:		<Sagar sk>
-- Create date: <15/10/2014>
-- Description:	<Ivy_UserRole_Update>
-- =============================================
-- Add the parameters for the stored procedure here
	(
				@UserKey int,
				@UserRoleKey int,
				@UserLoginID varchar(50) = NULL,
				@UserRoleCode nchar(20) = Null,

				@Sys_ModifiedByID varchar(50) = NULL,
				@Sys_DeleteType int = 0,
				@Sys_IsDeleted bit = false,
				@Sys_OrganizationID int = NULL,
				@Sys_InitialPrimaryKeys varchar(max)= NULL,
				@Sys_WorkstationName varchar(50)= NULL,
				@ConcurrencyTimeStamp datetime = NULL,

				@Sys_DateOfModification datetime OUTPUT
	)
AS
BEGIN
	-- SET NOCOUNT ON added to prevent extra result sets from
	-- interfering with SELECT statements.
	SET NOCOUNT OFF;

	-- ConcurrencyTimeStamp is mandatory and it needs to check if any other user has changed the reord or not	
	IF @ConcurrencyTimeStamp = NULL
	BEGIN
		RAISERROR('Missing @ConcurrencyTimeStamp', 11,1);
	END
	DECLARE @CurrentModificationDate datetime;
	SET @CurrentModificationDate = (SELECT [Sys_DateOfModification] FROM [UserRole] WHERE [UserKey] = @UserKey AND [UserRoleKey] = @UserRoleKey);
	If @ConcurrencyTimeStamp != @CurrentModificationDate
	BEGIN
		RAISERROR('Record is Changed by another process', 11,1);
	END
	
	IF @Sys_WorkstationName = 'Default'	
	BEGIN
		SET @Sys_WorkstationName = (SELECT @@SERVERNAME);
	END
	DECLARE @CurrentDataTime datetime;
	SET @CurrentDataTime = GETDATE();
	
    UPDATE	[UserRole]
	SET 
			[UserLoginID] = (SELECT [UserLoginID] FROM [User] WHERE [UserKey] = @UserKey),
			[UserRoleCode] = (SELECT [RoleCode] FROM [Sys_RoleMaster] WHERE [RoleKey] = @UserRoleKey),

			[Sys_DateOfModification] = @CurrentDataTime,
			[Sys_ModifiedByID] = @Sys_ModifiedByID,
			[Sys_DeleteType] = @Sys_DeleteType,
			[Sys_IsDeleted] = @Sys_IsDeleted,
			[Sys_OrganizationID] = @Sys_OrganizationID,
			[Sys_InitialPrimaryKeys] = @Sys_InitialPrimaryKeys,
			[Sys_WorkstationName] = @Sys_WorkstationName
	 WHERE
		(
			[UserKey] = @UserKey And 
			[UserRoleKey] = @UserRoleKey

			
		);
		SET @Sys_DateOfModification = @CurrentDataTime;

END
GO
